<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <script src="../js/vue.js"></script>
</head>
<body>
  <script>
    let number=18;
    let person={
        name:'张三',
        sex:'男'
  }

  Object.defineProperty(person,'age',{
    // value:18,
    // enumerable:true,       //控制属性是否可以枚举，默认值false
    // writable:true,         //控制属性是否可以被修改，默认值false
    // configurable:true,     //控制属性是否可以被删除，默认值false

    //当有人读取到person的age属性时，get函数(getter)就会被调用，并且返回值就是age的值
    // get:function(){   
      get(){    //简写
        console.log('有人读取了age属性');
      return number;
    },
    // 当有人修改person的age属性时，set函数(setter)就会被调用，且会收到修改的具体值
    set(value){
    console.log("有人修改了age属性");
    number=value;
    }
       
  })
  console.log(person);
  </script>
</body>
</html> 